import { Card, Form, Input, Checkbox, Button, message } from 'antd';
import logo from '@/assets/logo.png';
import './index.scss';
import useStore from '@/store';
import { useNavigate } from 'react-router-dom';

const Login = () => {
  const { loginStore } = useStore();
  const navigate = useNavigate();
  const onFinish = async values => {
    const { mobile, code } = values;
    try {
      await loginStore.getToken({ mobile, code });
      navigate('/', { replace: true });
      message.success('登录成功!');
    } catch (err) {
      message.error(err.response?.data.message || '登录失败!')
    }
  };

  return (
    <div className="login">
      <Card className="login-container">
        <img className="login-logo" src={logo} alt="" />
        {/* 登录表单 */}
        <Form
          initialValues={{ remember: true, mobile: '13911111111', code: '246810' }}
          validateTrigger={['onBlur', 'onChange']}
          onFinish={onFinish}
        >
          <Form.Item
            name="mobile"
            rules={[
              {
                pattern: /^1[3-9]\d{9}$/,
                message: '请输入正确的手机号!',
                validateTrigger: 'onBlur',
              },
              { required: true, message: '请输入手机号!' },
            ]}
          >
            <Input size="large" placeholder="请输入手机号" />
          </Form.Item>
          <Form.Item
            name="code"
            rules={[
              {
                len: 6,
                message: '请输入6位验证码!',
                validateTrigger: 'onBlur',
              },
              { required: true, message: '请输入验证码!' },
            ]}
          >
            <Input size="large" placeholder="请输入验证码" />
          </Form.Item>
          <Form.Item name="remember" valuePropName="checked">
            <Checkbox className="login-checkbox-label">
              我已阅读并同意「用户协议」和「隐私条款」
            </Checkbox>
          </Form.Item>
          <Form.Item>
            <Button type="primary" htmlType="submit" size="large" block>
              登录
            </Button>
          </Form.Item>
        </Form>
      </Card>
    </div>
  );
};

export default Login;
